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5 Background Of The Invention 

1 . Field of the Invention 

This invention is related to a technique and method for handling the amount of 
information retrieved from a search request sent to an Internet search engine, 
particularly wherein the user at the client computer side may dynamically change the 
10 depth of information from a search result abstract. 

2. Description of Related Art 

The advent of the Internet as an everyday useful tool in gathering information as 
gained considerable momentum in the past decade. People using the Internet today can 
15 be as diverse as an elementary school student searching an on-line encyclopedia to 
complete a homework assignment to a scientist looking for the latest articles in their 
field of research. There is so much information available on the Internet but there is 
still very little organization to the Internet that sometimes it may seem impossible to 
- fifid the right information or documents that you want without having to wade through a 
20 seemingly endless list of search results. 

One method of structuring information on the Internet is an index. Indexes 
allow the user to browse through information which has been organized according to 
categories such as sports, arts, business, etc., and their corresponding subcategories. 
One popular index on the Internet today is Yahoo!®. By selecting a category and/or a 
25 subcategory, the user finally gets to a list of documents and their uniform resource 
locators for further browsing. 
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Another popular way of finding information is to use search engines which are 
massive databases that cover huge portions of the Internet. Unlike an index, a search 

* engine does not return the data in categories but as a list of hits which contain, in 
decreasing order, the user's key word match. Typically, an Internet search engine 

5 returns a result set for a search query consisting of a URL (uniform resource locator) 
and a text based abstract of the original resource. Oftentimes, the user is able to 
control the length of the abstract. For example, HotBot® search engine at URL 
http : //www . hotbot . com provides the user with a choice of displaying the search results 
as a list of URLs, the URL with a brief abstract, or a comprehensive abstract. 

10 However, since the abstract has been compiled at the server site, once the 

abstract has been retrieved, there is no way of changing the abstract detail level without 
issuing a new query specifying a different level of detail in the abstract. Moreover, 
today's search engines do not provide the capability which allows a user to "zoom" in 
or out of an abstract thereby allowing the user to review search results more quickly 

15 and efficiently. 

Bearing in mind the problems and deficiencies of the prior art, it is therefore an 
object of the present invention to provide a method of reviewing search results more 
quickly and efficiently for the Internet user searching for information. 

* It is another object of the present invention to provide a method of dynamically 
20 controlling the level of information from a list of search result abstracts at the client 

computer. 

A further object of the invention is to provide a method of "zooming" in and out 
of the abstract wherein the user controls the level of detail to be displayed in the search 
result abstract. 

25 Still other objects and advantages of the invention will in part be obvious and 

will in part be apparent from the specification. 
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Summary of the Invention 

The above and other objects and advantages, which will be apparent to one of 
skill in the art, are achieved in the present invention which is directed to, in a first 
aspect, a method of summarizing a search result abstract on a client computer 
5 comprising the steps of initializing search parameters including defining a zoom level to 
define a search window comprising one or more words within the search result abstract; 
searching a first word within the search window to determine whether it is an indexable 
word; and adjusting the search parameters to move the search window throughout the 
search result abstract until a last search window is searched for an indexable word. The 

10 method of the first aspect further includes the step of displaying all found indexable 
words of the search result abstract. Other initial search parameters which may be 
initialized include, but are not limited to, a zoom function, a base index value, an offset 
value; a maximum search window, and a skip value. 

In a second aspect, the present invention is directed to a method of locating 

15 indexable words within a search result abstract retrieved from a search engine 
comprising the steps of assigning a sequential number to each word of the search result 
abstract; determining a zoom level; defining a maximum search window based on the 
zoom level; setting a base index at a first word of the search result abstract wherein the 
base index has an initial value of one, the base index being a focal pomt of the 

20 maximum search window; searching for an indexable word at the base index; searching 
for an indexable word within the search window when the first word at the base index 
is not an indexable word; setting the base index at other words within the search 
window to establish a subsequent search window and searching for indexable words 
within the subsequent search window; and displaying a condensed abstract comprising 

25 found indexable words in the search result abstract. The method may further include 
the step of determining whether to fix the base index at a found indexable word as a 
basis for the step of setting the base index at other words within a subsequent search 
window. Preferably, the step of searching for indexable words within the search 
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window comprises searching a number of words to the right and left of the base index 
within the maximum search window for an indexable word. 

In a third aspect, the present invention is directed to a method of dynamically 
generating differing levels of detail in a search result abstract on a user computer 
5 comprising the steps of engaging a zoom function; determining a zoom level as set by a 
user of the user computer; determining whether a random window flag is set; assigning 
sequential numbers to each word of the search result abstract; initially setting a base 
index at a first word of the search result abstract; initially setting an offset value as a 
word at the base index; determining a maximum search window based on a value of the 
10 zoom level; determining a skip value based on the zoom level; determining whether a 
fix base index flag is set; searching a first maximum search window for an indexable 
word at the base index; searching subsequent maximum search windows for an 
indexable word at an index comprising the base index and the offset value; determining 
whether the offset value is greater than a value of the maximum search window wherein 
15 if the offset value is greater than the value of the maximum search window, then setting 
the index at a word corresponding to a value of the base index and the skip value; 
determining whether a word at the index is an indexable word wherein if the word at 
the index is not an indexable word, then adjusting the offset value such that another 
word is at the index; setting the base index to the indexable word at the indent when the 
20 * fix base index flag is set; and setting the index to the word corresponding to a value of 
the base index and the skip value when the fix base index flag has not been set. 

Preferably, the step of adjusting the offset value comprises the steps of picking a 
random number within the maximum search window having a value greater than a 
negative value of the maximum search window and less than a value of the maximum 
25 search window when the random window flag has not been set; determining whether 
the offset value is equal to zero if the random window flag has not been set; obtaining 
another offset value by increasing the offset value by one if the offset value is 
^ determined to be equal to zero; determining whether the offset value is greater than 
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zero if the offset value is not equal to zero; obtaining another offset value by 
multiplying the offset value by negative one and adding one if the offset value is greater 
• tfian zero; and obtaining another offset value by multiplying the offset value by negative 
one if the offset value is less than zero. 
5 In a fourth aspect, the present invention is directed to an article of manufacture 

comprising a computer usable medium having computer readable program code means 
embodied therein for causing a computer to dynamically summarize a search result 
abstract, the computer readable program code means in the article of manufacture 
comprising computer readable program code means for causing a computer to initialize 

10 search parameters including defining a search window comprising one or more words 
within the search result abstract; computer readable program code means for causing 
the computer to search the words within the search window for an indexable word; and 
computer readable program code means for causing the computer to adjusting the 
search parameters to move the search window throughout the search result abstract until 

15 a last search window is searched for an indexable word. 

In a fifth aspect, the present invention is directed to an article of manufacture 
comprising a computer usable medium having computer readable program code means 
embodied therein for causing a computer to locate indexable words within a search 
result abstract retrieved from a search engine, the computer readable program code 

20 ' means in the article of manufacture comprising computer readable program code means 
for causing a computer to assign a sequential number to each word of the search result 
abstract; computer readable program code means for causing the computer to determine 
a zoom level; computer readable program code means for causing the computer to 
define a maximum search window comprising one or more words based on the zoom 

25 level; computer readable program code means for causing the computer to set a base 
index at a first word of the search result abstract wherein the base index has an initial 
value of one, the base index being a focal point of the maximum search window; 
"^cdmputer readable program code means for causing the computer to search for an 
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indexable word at the base index; computer readable program code means for causing 
the computer to search for an indexable word within the search window when the first 
=word at the base index is not an indexable word; computer readable program code 
means for causing the computer to set the base index at other words to establish a 
5 subsequent search window and searching for indexable words within the subsequent 
search window; and computer readable program code means for causing the computer 
to display indexable words in accordance with the zoom level. 

In a sixth aspect, the present invention is directed to an article of manufacture 
comprising a computer usable medium having computer readable program code means 
10 embodied therein for causing a computer to dynamically generate differing levels of 
p detain in a search result abstract, the computer readable program code means in the 

(ii article of manufacture comprising: computer readable program code means for causing 

^: a computer to engage a zoom function; computer readable program code means for 

CJi causing the computer to determine a zoom level; computer readable program code 

m 15 means for causing a computer to determine whether a random window flag is set; 

!L computer readable program code means for causing a computer to assign sequential 

=p numbers to each word of the search result abstract; computer readable program code 

^4 means for causing a computer to initially set a base index at a first word of the search 

result abstract; computer readable program code means for causing a computer to 
20 'initially set an offset value as a word at the base index; computer readable program 
code means for causing a computer to determine a maximum search window based on a 
value of the zoom level, the maximum search window; computer readable program 
code means for causing a computer to determine a skip value based on the zoom level, 
the skip value equal to one less than twice the value of the zoom level; computer 
25 readable program code means for causing a computer to determine whether a fix base 
index flag is set; computer readable program code means for causing a computer to 
search a first maximum search window for an indexable word at the base index; 
^cdTnputer readable program code means for causing a computer to search subsequent 
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maximum search windows for an indexable word at an index comprising the base index 
and the offset value; computer readable program code means for causing a computer to 
-determine whether the offset value is greater than a value of the maximum search 
window wherein if the offset value is greater than the value of the maximum search 
5 window, then setting the index [or the base index] at a word corresponding to a value 
of the base index and the skip value; computer readable program code means for 
causing a computer to determine whether a word at the index is an indexable word 
wherein if the word at the index is not an indexable word, then to adjust the offset value 
such that the index is set to another word; computer readable program code means for 
10 causing a computer to set the base index to the indexable word at the index when the fix 
base index flag is set; and computer readable program code means for causing a 
computer to set the index to the word corresponding to a value of the base index and 
the skip value when the fix base index flag has not been set. 



15 Brief Description of the Drawings 

The features of the invention believed to be novel and the elements characteristic 
of the invention are set forth with particularity in the appended claims. The figures are 
for illustration purposes only and are not drawn to scale. The invention itself, 
however, both as to organization and method of operation, may best be understood by 
20 reference to the detailed description which follows taken in conjunction with the 
accompanying drawings in which: 

Fig. 1 is a schematic representation of the program architecture of the present 
invention. 

Fig. 2 is a flow diagram illustrating the overall method steps of the present 
25 invention. 

Fig. 3 is a flow diagram illustrating the method of finding a next indexable word 
~^hfa search window in accordance with the present invention. 
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Fig. 4 is a flow diagram illustrating the method of finding a next indexable word 
in a search window when a word is not an indexable word in accordance with the 
* present invention. 

5 Description of the Preferred Embodiment(s) 

In describing the preferred embodiment of the present invention, reference will 
be made herein to Figs. 1-4 of the drawings in which like numerals refer to like 
features of the invention. Features of the invention are not necessarily shown to scale 
in the drawings. 

10 Generally, the present invention provides the Internet user the ability to increase 

or decrease the abstract detail level for a text based resource retrieved from a list of 
search engine results at the user computer. Preferably, the present invention is 
embodied as a software program used in conjunction with a web browser incorporating 
known program source code or as a plug-in (a file containing data used to alter, 

15 enhance, or extend the operation of a parent application). Typical web browser 
programs including Netscape Navigator® available from Netscape Communications, 
Inc. or Internet Explorer® available from Microsoft, Inc. would support such a plug-in. 
The program source code embodying the present invention may be encQded in a 
- tangible media which creates the means for causing the computer to perform the various 

20 steps of the present invention. 

The software architecture of the present invention is illustrated in Fig. 1. A 
user sends out a search request via a web browser to a search engine. The search 
engine returns a list of search results containing a list of URLs and a very brief 
abstract. Once the user determines whether the search result is of interest, the user 
25 engages the present invention, preferably embodied as a software program, to "zoom 
out" of the abstract thereby retrieving greater details of the abstract to further determine 
^ whether the resource is useful or not. This process may be repeated as long as the 
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"zoom" level satisfies the user's needs. The user is also able to "zoom in" on the 
abstract to diminish the detail level The present invention provides a "zoom 11 manager 
* as a means for enabling the "zooming" function and determining the "zoom" level set 
by the user. In addition to the "zoom" manager, the present invention also provides for 
5 a query manager which interfaces with the "zoom" manager, the client computer, and 
the search engine. Advantageously, the process of the present invention is performed 
entirely on the user side without having to reset the abstract level at the server side with 
a new query. The present invention could also be useful as a filter for email 
applications to let users quickly identify the contents of an email message allowing junk 
10 email or spam to be easily detected. 

Fig. 2 is a flow diagram illustrating the overall method steps of the present 
invention beginning at 200 wherein each word of the abstract is determined to be an 
indexable word or a noise word beginning with the first word of the abstract. An 
indexable word is generally a noun or verb or other key word which would be of 
15 interest to the user. A noise word is typically a non-key word, e.g., pronoun, "to", 
"the", and the like. A dictionary of indexable words and noise words may be 
incorporated as a searchable table into the present invention. 

A series of zooming parameters must be initialized 210 prior to searching for 
, indexable words in the abstract. Such parameters include, but are not limited to, a 

20 "zoom" level, a maximum search window, a random window flag, a base index, an 
offset value, a fix base index flag, and a skip value. The "zoom" level may have a 
value of zero or greater which determines the size of a maximum search window. The 
maximum search window has a value which is one less than the "zoom" level 
representing the maximum number of words within a search window which can be 

25 searched for an indexable word. When the present invention searches for an indexable 
word in the abstract, a windowing technique is utilized. For example, if the "zoom" 
level is 3, the maximum search window has a value of 2, thus, two words to the right 
and left of the index are searched for an indexable word. Since noise words are 
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undesirable and will not provide much useful information to the user, another word will 
be searched for within the maximum window of words. 

A random window flag may also be initialized at this juncture that if engaged a 
random windowing technique is used to locate another indexable word within the 
5 maximum search window when a found word is a noise word. A random number 
within the maximum search window size may be selected and the word located at the 
selected random number is determined to be an indexable word. Thus, the random 
number will have a value that is greater than a negative value of the maximum search 
window and less than the value of the maximum search window. A temporary storage 
10 table may be created to keep track of which words have already been searched within 
the maximum window to find indexable words so that a word previously searched will 
not be searched again. 

The base index is initially set to a value of 1 relating to the first word of the 
abstract as a starting point from which the words in the abstract are searched to find 

15 indexable words which may be sought and displayed to the user when "zooming" has 
been engaged and a "zoom" level greater than 1 has been chosen. It will be shown that 
each word in the abstract will be sequentially numbered beginning with the base index. 
As each word of the abstract is searched to determine whether it is an indexable word, 
thp base index is a constantly shifting focal point within the maximum search window 

20 until each search window of the abstract has been searched. 

An offset value is the maximum number of words to the right and left of the 
base index within the maximum search window with the base index acting as a focal 
point within the maximum search window. It is initially set to zero representing a zero 
distance from the base index and can be increased so long as it does not extend outside 
25 the maximum search window value. The offset value is the number of words away 
from the base index word within the maximum search window determined to be either 
^.an-indexable word or a "noise" word. When the word at the base index is not an 
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indexable word, the offset value can be adjusted so that an indexable word may be 
located within the particular search window. 

The fix base index flag is used to indicate which indexable word, the absolute 
indexable word or the found indexable word, is used as the basis from which the next 
5 indexable word is found. If the fix base index flag has been set, the base index is set to 
the found indexable word as the basis upon which the next word is located. However, 
if the fix base index flag has not been set, the base index is moved forward by adding 
the skip value as a basis for locating the next indexable word. 

The skip value is equal to one less than twice the value of the zoom level. It is 
10 used in determining a new base index when the fix base index flag has not been set and 
when the offset value is zero. 

The "zooming" is engaged when selected by the user which in turn initializes 
the parameters discussed above. The present invention proceeds to search the first 
window for an indexable word 220. For example, if the zoom level has a value of 2, 
15 the maximum search window is therefore one word to the right and left of the base 
index. Subsequently, once the first window is searched, it is determined whether there 
are subsequent windows 230 which need to be searched until there are no additional 
windows and the process ends 240. This method of searching the maximum search 
* window is illustrated in the flow diagram of Fig. 3 with the process of looking at the 
20 next search window beginning at 300. 

At the beginning of the search abstract, the maximum search window has only 
the word at the base index and the words to the right of the base index within the 
maximum search window. There are no words to the left of the base index at the 
beginning of the abstract. In searching the first search window, an index is set 310 
25 from the original base index having a value of 1, and adding the value for the offset 
value, initially set at zero, such that the index is located at the base index or the first 
word of the abstract. The offset value is compared 320 to the value of the maximum 
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search window to determine if the offset value is greater than the value of the maximum 
search window. If the offset value is not greater than the value of the maximum search 
'window, and it will not be greater when searching within that first search window since 
the offset value has an initial value of zero, the word at the index is searched to see if it 
5 is an indexable word 330. If the word at the index is an indexable word, the fix base 
index flag is considered 340. When the fix base index flag has been engaged at the 
time the initial parameters were initialized, the base index is then set to the indexable 
word 360. The word at the index is now the basis for finding the next indexable word. 

Referring back to step 320, if the offset value is greater than the value of the 
10 maximum search window as in the case of searching windows occurring later on as the 
abstract is searched, the base index is set from the current base index and moved in 
accordance with a skip value 350 which was previously initialized and the next window 
with the new base index is searched for an indexable word. Likewise, if the fix base 
index flag has not been engaged, the base index is set from the current base index 
15 moving in accordance with the skip value 350, and the next window is searched. 

When the word at the index is not an indexable word, the offset value must be 
adjusted. Fig. 4 illustrates a flow diagram wherein the maximum window representing 
the maximum searchable range of words in the abstract must be adjusted in order to 
Joeate the next indexable word. The process begins at 400 where it is determined 

20 whether the random window flag has been set 410. As discussed above, if the random 
window flag has been engaged, a random number is selected 470 having a value 
between a negative value of the maximum window value and a positive value of the 
maximum window so long as the value has not been previously used as the base index. 
This random number becomes the index from which the next indexable word is located 

25 (see 310). 

However, if the random window flag has not been engaged, the offset value is 
-*-a<£justed. First, it is determined whether the offset value has a value of zero 420. If the 
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offset value has a value of zero as it does when it is initially set, the offset value is 
increased by 1 so that one word to the right of the base index may be determined to be 
- ail indexable word 440 within the maximum search window. If the offset value does 
not have a value of zero, it is determined 430 whether it has a value greater than zero. 
5 The offset value which does not have a value greater than zero, a negative value, is 
multiplied by -1 and increased by 1 so that the word to the right of the base index may 
be determined to be an indexable word 450. The offset value which has a value greater 
than zero is multiplied by -1 to obtain a negative value so that the word to the left and 
before the base index may be determined to be an indexable word 460. Once the offset 
10 values have been adjusted, the window is again searched to determine whether the word 
at the new index is an indexable word. 

Once the present invention has searched every maximum search window for 
indexable words, a display function will display all the indexable words selected from 
the zooming process. Each word that has been found to be an indexable word is 
15 marked for display. Noise words will not be displayed since they provide little to no 
information to the user. Only when the user disengages the "zoom" function to review 
the entire abstract will all words in the search result abstract be displayed. 

Example #1 

-» 

^ ^ A search result initial abstract comprising "Yahoo! Address Book is a powerful 
20 online contact manager" is assigned sequential numbers as shown below wherein words 
4 and 5 are non-indexable noise words: 
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No. 


Word 


1 


Yahoo! 


--2' 


Address 


3 


Book 


4 


is 


5 


a 


6 


powerful 


7 


online 


8 


contact 


9 


manager 



The method of the present invention analyses the abstract when the user engages 
the zoom function to initialize the zooming parameters: 



Parameters Initial Value 

zoom level 2 

15 max. search window 1 

random window flag not set 

fix base index flag set 

base index 1 

offset 0 

20 - skip value 3 



The index is set at the first word of the abstract, "Yahoo!", since the index has a 
value of 1 comprising a value of the base index (initially set at 1) and the offset value 
(initially set at 0, thus, not greater than 1). The first word of the abstract, "Yahoo! " is 
determined to be an indexable word. When the fix base index flag is set, the base index 
25 is set to the first word, "Yahoo!", found to be an indexable word. "Yahoo!" will then 
be tagged for display in the condensed abstract. 

The base index then jumps to word 4. However, word 4, "is", is a non- 
indexable noise word, thus, another indexable word must be selected. The offset value 
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is adjusted by increasing it by 1 to determine whether word 5, "a", is an indexable 
word. Since word 5 is a non-indexable noise word, the offset value is again adjusted to 
• -T to determine whether word 3 is indexable. Word 3, "Book", is an indexable word 
and is tagged for display in the condensed abstract. Note that the maximum search 
5 window will encompass words 3, 4, and 5. 

The base index, at word 3, is moved in accordance with the skip value to word 
6, "powerful". Word 6 being an indexable word is tagged for display in the condensed 
abstract. The base index then jumps to word 9, "manager", and since it is also an 
indexable word is tagged for display in the condensed abstract. Since the last word of 
10 the abstract is word 9, the condensed abstract is displayed as follows: 



No. 


Displayed Word 


1 


Yahoo! 


2 


Address 


3 


Book 


6 


powerful 


7 


online 


8 


contact 


9 


manager 



The present invention achieves the objects recited above. The present method 
20 and technique allows users to "zoom" in and "zoom" out of a text based data source to 
generate a dynamical view of the data in a detail level controlled by the user. This 
allows a user to specify a convenient depth level in reviewing information particularly 
useful in Internet search results. The user can skim the search engine results more 
efficiently by changing the depth level of abstract information. The present invention 
25 makes information more manageable and provides functionality to users by identifying 
desired information more quickly given the overwhelming breadth of information 
available through the Internet. 
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While the present invention has been particularly described, in conjunction with 
a specific preferred embodiment, it is evident that many alternatives, modifications and 
'variations will be apparent to those skilled in the art in light of the foregoing 
description. It is therefore contemplated that the appended claims will embrace any 
5 such alternatives, modifications and variations as falling within the true scope and spirit 
of the present invention. 

Thus, having described the invention, what is claimed is: 
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/ Claims 

1 / A method of summarizing a search result abstract on a client computer 

2 / comprising the steps of: 

3 initializing search parameters including defining a zoom level to define a search 

4 window comprising one or more words within the search result abstract; 

5 searching a first word within the search window to determine whether it is an 

6 indexable word; and 

7 adjusting the search parameters to move the search window throughout the search 

8 result abstract until a last search window is searched for an indexable word. 

1 2. The method of claim 1 further includes the step of displaying all indexable 

2 words found in the search result abstract. 

1 3. The method of claim 1 wherein the step of initializing search parameters further 

2 includes engaging a zoom function. 

1 4. The method of claim 1 wherein the step of initializing search parameters further 

2 includes setting a base index value. 

1 5. The method of claim 4 wherein the step of initializing search parameters further 

2 includes setting the base index at an initial value of 1 such that a first word of the 

3 search result abstract within the search window is determined to be an indexable word. 

1 6. The method of claim 1 wherein the step of initializing search parameters farther 

2 includes the step of setting an offset value. 

1 7. The method of claim 1 wherein the step of initializing search parameters farther 

2 includes the step of determining a maximum search window 
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1 8. The method of claim 1 wherein the step of initializing search parameters further 

2 * includes the step of determining a skip value. 

1 9. The method of claim 1 wherein the step of searching the words within the search 

2 window for an indexable word comprises searching a word at a base index within the 

3 search window to determine whether the word at the base index is an indexable word. 

1 10. The method of claim 1 wherein the step of searching the word at the base index 

2 within the search window for an indexable word does not locate an indexable word, the 

3 method further includes the steps of: 

4 setting an index at a word within the search window to a value equal to the base 

5 index and an offset value within a maximum search window; 

6 determining whether the word at the index is an indexable word; and 

7 determining whether to set the base index at the word to the index if the word at the 

8 index is an indexable word, 

1 11, The method of claim 10 wherein the step of determining whether a word at the 

2 index is an indexable word does not locate an indexable word at the index, thtn the step 

3 of determining whether a random number within the maximum search window may be 

4 selected to obtain an another offset value occurs, the random number being greater than 

5 a negative value of the maximum search window and less than a value of the maximum 

6 search window, 

1 12. The method of claim 11 wherein the step of determining whether a random 

2 number within the maximum search window may be selected to obtain an another offset 

3 value does not indicate that a random number may be selected, then the step of 

4 adjusting the offset value until a new index is obtained occurs. 
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1 13. The method of claim 10 farther including the step of searching within a 

2 - subsequent search window for an indexable word. 

1 14. A method of locating indexable words within a search result abstract retrieved 

2 from a search engine comprising the steps of: 

3 assigning a sequential number to each word of the search result abstract; 

4 determining a zoom level; 

5 defining a maximum search window based on the zoom level; 

6 setting a base index at a first word of the search result abstract wherein the base 

7 index has an initial value of one, the base index being a focal point of the 

8 maximum search window; 

9 searching for an indexable word at the base index; 

10 searching for an indexable word within the search window when the first word at 

11 the base index is not an indexable word; 

12 setting the base index at other words within the search window to establish a 

13 subsequent search window and searching for indexable words within the 

14 subsequent search window; and 

15 displaying a condensed abstract comprising found indexable words in the search 

16 " * result abstract. 

1 15. The method of claim 14 farther including the step of determining whether to fix 

2 the base index at a found indexable word as a basis for the step of setting the base index 

3 at other words within a subsequent search window. 

1 16. The method of claim 14 wherein the step of searching for indexable words 

2 within the search window comprises searching a number of words right and left of the 

3 ^ base index within the maximum search window for an indexable word. 



AM9-99-0097 



19 



1 17. The method of claim 14 wherein the step of setting the base index at other 

2 * words to establish a subsequent search window and searching for indexable words 

3 within the subsequent window comprises adjusting the base index by a skip value to 

4 obtain a new focal point for a subsequent search window. 

1 18. The method of claim 14 wherein the step of setting the base index at other 

2 words to establish a subsequent search window and searching for indexable words 

3 within the subsequent window comprises adjusting the base index by an offset value to 

4 obtain a new focal point for a subsequent search window when a word at the index is 

5 not an indexable word. 

1 t J/^ A method of dynamically generating differing levels of detail in a search result 

2 abstract on a user computer comprising the steps of: 

3 engaging a zoom function; 

4 determining a zoom level as set by a user of the user computer; 

5 determining whether a random window flag is set; 

6 assigning sequential numbers to each word of the search result abstract; 

7 initially setting a base index at a first word of the search result abstract; * 

8 initially setting an offset value as a word at the base index; 

9 determining a maximum search window based on a value of the zoom level; 

10 determining a skip value based on the zoom level; 

1 1 determining whether a fix base index flag is set; 

12 searching a first maximum search window for an indexable word at the base index; 

13 searching subsequent maximum search windows for an indexable word at an index 

14 comprising the base index and the offset value; 

15 determining whether the offset value is greater than a value of the maximum search 

16 ^ ^ window wherein if the offset value is greater than the value of the maximum 
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17 search window, then setting the index at a word corresponding to a value of the 

18 base index and the skip value; 

19 * r determining whether a word at the index is an indexable word wherein if the word 

20 at the index is not an indexable word, then adjusting the offset value such that 

21 another word is at the index; 

22 setting the base index to the indexable word at the index when the fix base index 

23 flag is set; and 

24 setting the index to the word corresponding to a value of the base index and the skip 

25 value when the fix base index flag has not been set. 

1 20. The method of claim 19 wherein the step of adjusting the offset value comprises 

2 the steps of: 

3 picking a random number within the maximum search window having a value 

4 greater than a negative value of the maximum search window and less than a 

5 value of the maximum search window when the random window flag has not 

6 been set; 

7 determining whether the offset value is equal to zero if the random window flag has 

8 not been set; 

9 obtaining another offset value by increasing the offset value by one if The offset 

10 value is determined to be equal to zero; 

11 determining whether the offset value is greater than zero if the offset value is not 

12 equal to zero; 

13 obtaining another offset value by multiplying the offset value by negative one and 

14 adding one if the offset value is greater than zero; and 

15 obtaining another offset value by multiplying the offset value by negative one if the 

16 offset value is less than zero. 
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1 2L The method of claim 20 further including the step of continuing to search the 

2 subsequent maximum search windows. 

1 An article of manufacture comprising: 

2 a computer usable medium having computer readable program code means 

3 embodied therein for causing a computer to dynamically summarize a search 

4 result abstract, the computer readable program code means in the article of 

5 manufacture comprising: 

6 computer readable program code means for causing a computer to initialize search 

7 parameters including defining a search window comprising one or more words 

8 within the search result abstract; 

9 computer readable program code means for causing the computer to search the 

10 words within the search window for an indexable word; and 

11 computer readable program code means for causing the computer to adjusting the 

12 search parameters to move the search window throughout the search result 

13 abstract until a last search window is searched for an indexable word. 

1 23. The article of claim 22 wherein the computer readable program code means for 

2 causing the computer to search the words within the search window for an^indexable 

3 word further comprises: 

4 computer readable program code means for causing a computer to set an index at a 

5 word within the search window to a value equal to a base index and an offset 

6 value when the computer readable program code means for causing the 

7 computer to search the words within the search window for an indexable word 

8 does not locate an indexable word; 

9 computer readable program code means for causing the computer to determine 
10 whether the offset value is greater than a maximum window value; 
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11 computer readable program code means for causing the computer to set the base 

12 index to a value equal to the base index and a skip value if the offset value is 

13 • " greater than a maximum window value; 

14 computer readable program code means for causing the computer to determine 

15 whether a word at the index is an indexable word if the offset value is not 

16 greater than a maximum window value; and 

17 computer readable program code means for causing the computer to determine 

18 whether to set the base index at the word at the index if the word at the index is 

19 an indexable word. 

1 24. The article of claim 23 wherein the computer readable program code means for 

2 causing the computer to determine whether a word at the index is an indexable word 

3 further comprises: 

4 computer readable program code means for causing the computer to determine 

5 whether a random number within the maximum search window may be selected 

6 to obtain an another offset value occurs, the random number being greater than 

7 a negative value of the maximum search window and less than a value of the 

8 maximum search window. 

1 An article of manufacture comprising: 

2 a computer usable medium having computer readable program code means 

3 embodied therein for causing a computer to locate indexable words within a 

4 search result abstract retrieved from a search engine, the computer readable 

5 program code means in the article of manufacture comprising: 

6 computer readable program code means for causing a computer to assign a 

7 sequential number to each word of the search result abstract; 

8 computer readable program code means for causing the computer to determine a 

9 ^ zoom level; 
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10 computer readable program code means for causing the computer to define a 

11 maximum search window comprising one or more words based on the zoom 

12 • r level; 

13 computer readable program code means for causing the computer to set a base index 

14 at a first word of the search result abstract wherein the base index has an initial 

15 value of one, the base index being a focal point of the maximum search window; 

16 computer readable program code means for causing the computer to search for an 

17 indexable word at the base index; 

18 computer readable program code means for causing the computer to search for an 

19 indexable word within the search window when the first word at the base index 

20 is not an indexable word; 

21 computer readable program code means for causing the computer to set the base 

22 index at other words to establish a subsequent search window and searching for 

23 indexable words within the subsequent search window; and 

24 computer readable program code means for causing the computer to display 

25 indexable words in accordance with the zoom level. 

1 — J ^6. An article of manufacture comprising: 

2 a computer usable medium having computer readable program code means 

3 * embodied therein for causing a computer to dynamically generate differing 

4 levels of detain in a search result abstract, the computer readable program code 

5 means in the article of manufacture comprising: 

6 computer readable program code means for causing a computer to engage a zoom 

7 function; 

8 computer readable program code means for causing the computer to determine a 

9 zoom level; 

10 computer readable program code means for causing a computer to determine 

11 ~~ whether a random window flag is set; 
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12 computer readable program code means for causing a computer to assign sequential 

13 numbers to each word of the search result abstract; 

14 ' r computer readable program code means for causing a computer to initially set a 

15 base index at a first word of the search result abstract; 

16 computer readable program code means for causing a computer to initially set an 

17 offset value as a word at the base index; 

18 computer readable program code means for causing a computer to determine a 

19 maximum search window based on a value of the zoom level, the maximum 

20 search window; 

21 computer readable program code means for causing a computer to determine a skip 

22 value based on the zoom level, the skip value equal to one less than twice the 

23 value of the zoom level; 

24 computer readable program code means for causing a computer to determine 

25 whether a fix base index flag is set; 

26 computer readable program code means for causing a computer to search a first 

27 maximum search window for an indexable word at the base index; 

28 computer readable program code means for causing a computer to search 

29 subsequent maximum search windows for an indexable word at an index 

30 comprising the base index and the offset value; 

31 computer readable program code means for causing a computer to determine 

32 whether the offset value is greater than a value of the maximum search window 

33 wherein if the offset value is greater than the value of the maximum search 

34 window, then setting the index at a word corresponding to a value of the base 

35 index and the skip value; 

36 computer readable program code means for causing a computer to determine 

37 whether a word at the index is an indexable word wherein if the word at the 

38 index is not an indexable word, then to adjust the offset value such that the 

39 index is set to another word; 
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40 computer readable program code means for causing a computer to set the base index 

41 to the indexable word at the index when the fix base index flag is set; and 

42 - ~ computer readable program code means for causing a computer to set the index to 

43 the word corresponding to a value of the base index and the skip value when the 

44 fix base index flag has not been set. 

1 27. The article of claim 26 wherein the computer readable program code means for 

2 causing a computer to adjust the offset value such that the index is set to another word 

3 comprises: 

4 computer readable program code means for causing the computer to pick a random 

5 number within the maximum search window having a value greater than a 

6 negative value of the maximum search window and less than a value of the 

7 maximum search window when the random window flag has not been set; 

8 computer readable program code means for causing the computer to determine 

9 whether the offset value is equal to zero if the random window flag has not been 

10 set; 

1 1 computer readable program code means for causing the computer to obtain another 

12 offset value by increasing the offset value by one if the offset value is 

13 determined to be equal to zero; 

14 " computer readable program code means for causing the computer to determine 

15 whether the offset value is greater than zero if the offset value is not equal to 

16 zero; 

17 computer readable program code means for causing the computer to obtain another 

18 offset value by multiplying the offset value by negative one and adding one if 

19 the offset value is greater than zero; and 

20 computer readable program code means for causing the computer to obtain another 

21 offset value by multiplying the offset value by negative one if the offset value is 

22 ^ -~ less than zero. 
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TECHNIQUE AND METHOD WHICH DYNAMICALLY GENERATES 
VARIOUS DEPTH LEVELS OF ABSTRACTS FOR TEXT BASED DATA 

SOURCES ON DEMAND 

ABSTRACT OF THE DISCLOSURE 

5 The present invention discloses a method for dynamically generating an abstract 

from a search result abstract retrieved from a search engine. Preferably embodied as a 
software program, the present invention allows a user to "zoom" in and out of the 
abstract thereby retrieving greater or lesser details of the abstract to further determine 
whether the resource is useful or not. Groups of words within the search result abstract 
10 are searched for indexable words or key words useful to the user. The indexable words 
are then displayed to the user. Advantageously, the process of the present invention is 
performed entirely on the user side without having to reset the abstract level at the 
server side with a new query. 
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Address al! telephone calls to: Shirley S. Ma of DeLIO & PETERSON, LLC at (203) 787-0595. 

Address all correspondence to: DeLIO & PETERSON, LLC 

121 Whitney Avenue 
New Haven, CT 06510 

I hereby declare that all statements made herein of my own knowledge are true and that all 
statements made on information and belief are believed to be true; and further that these 
statements were made with the knowledge that willful false statements and the I. ke so 
made are punishable by fine or impris6nment, or both, under Section 1001 of Tide 18 of 
the United States Code and that such willful false statements may jeopardize the validity of 
the application or any patent issued thereon. 

(1) Inventor: Reiner Kraft 



Signature: 



Date 

Residence: 9406 Wetsand Court, Gilroy, CA 95020 
Citizenship: Germany 
Post Office 

Address: SAME AS RESIDENCE 
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(2) Inventor: 
Signature: 

Residence: 

Citizenship: 

Post Office 
Address: 

(3) Inventor: 
Signature: 

Residence: 

Citizenship: 

Post Office 
Address: 



Michael L Emens 



Date 



6530 Korematsu Court, San Jose, CA 95120 
USA 

SAME AS RESIDENCE 
Gaurav Tewari 

Courtis/ ffaOtf' 



flflttL \ 20Q O 



Date 



3 Ames Street #353, Cambridge, MA 02142 
India 

SAME AS RESIDENCE 



1BM100002000DEC 
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